package cn.icatw.leetcode.editor.cn;
//给定 s 和 t 两个字符串，当它们分别被输入到空白的文本编辑器后，如果两者相等，返回 true 。# 代表退格字符。
//
// 注意：如果对空文本输入退格字符，文本继续为空。
//
//
//
// 示例 1：
//
//
//输入：s = "ab#c", t = "ad#c"
//输出：true
//解释：s 和 t 都会变成 "ac"。
//
//
// 示例 2：
//
//
//输入：s = "ab##", t = "c#d#"
//输出：true
//解释：s 和 t 都会变成 ""。
//
//
// 示例 3：
//
//
//输入：s = "a#c", t = "b"
//输出：false
//解释：s 会变成 "c"，但 t 仍然是 "b"。
//
//
//
// 提示：
//
//
// 1 <= s.length, t.length <= 200
// s 和 t 只含有小写字母以及字符 '#'
//
//
//
//
// 进阶：
//
//
// 你可以用 O(n) 的时间复杂度和 O(1) 的空间复杂度解决该问题吗？
//
//
// Related Topics 栈 双指针 字符串 模拟 👍 723 👎 0


//Java：比较含退格的字符串
public class T844_BackspaceStringCompare {
    public static void main(String[] args) {
        Solution solution = new T844_BackspaceStringCompare().new Solution();
        // TO TEST
        solution.backspaceCompare("a#c", "t");
    }

    //leetcode submit region begin(Prohibit modification and deletion)
    class Solution {
        public boolean backspaceCompare(String s, String t) {
            return processString(s).equals(processString(t));
        }

        private String processString(String str) {
            char[] charArray = str.toCharArray();
            int slow = 0;
            for (int fast = 0; fast < charArray.length; fast++) {
                //    定义快慢指针
                if (charArray[fast] != '#') {
                    charArray[slow] = charArray[fast];
                    slow++;
                } else {
                    if (slow > 0) {
                        slow--;
                    }

                }
            }
            //分割字符串
            String result = new String(charArray).substring(0, slow);
            //String result = Arrays.toString(charArray).substring(0, slow);
            System.out.println(result);
            return result;
        }
    }
//leetcode submit region end(Prohibit modification and deletion)

}
